Skip to main content

GitHub App Installation Deletion Endpoint

Overview

This endpoint allows users to delete a specific GitHub app installation associated with their account.

Request Details

HTTP Method

DELETE

Route

/api/users/[user_id]/installations/[installation_id]

Route Parameters

ParameterTypeRequiredDescription
user_idintegerYesThe ID of the authenticated user
installation_idintegerYesThe ID of the GitHub app installation

Headers

HeaderValueRequiredDescription
Acceptapplication/jsonYesSpecifies the response format
Cookieneptun-sessionYesSession authentication cookie

Query Parameters

No query parameters required.

Request Body

No request body required.

Response Format

Response Status Codes

Status CodeDescription
200Successfully deleted GitHub app installation
401Unauthorized (invalid or missing session)
403Forbidden (user_id mismatch)
404Installation not found
500Server error

Success Response (200 OK)

Returns true on successful deletion.

true

Error Response (404 Not Found)

{
"statusCode": 404,
"message": "Installation not found"
}

TypeScript Interface

type ApiResponse = boolean

Python Model

from pydantic import BaseModel

class ApiResponse(BaseModel):
success: bool

Code Examples

cURL Example

curl -X DELETE "https://neptun-webui.vercel.app/api/users/1/installations/1" \
-H "Accept: application/json" \
-H "Cookie: neptun-session=your-session-cookie"

Python Example

import httpx

async def delete_github_app_installation(
user_id: int,
installation_id: int,
session_cookie: str
) -> bool:
url = f"https://neptun-webui.vercel.app/api/users/{user_id}/installations/{installation_id}"

async with httpx.AsyncClient() as client:
response = await client.delete(
url,
headers={
"Accept": "application/json",
"Cookie": f"neptun-session={session_cookie}"
}
)
response.raise_for_status()
return response.json()

TypeScript/JavaScript Example

async function deleteGithubAppInstallation(
userId: number,
installationId: number,
sessionCookie: string
): Promise<boolean> {
const response = await fetch(
`https://neptun-webui.vercel.app/api/users/${userId}/installations/${installationId}`,
{
method: 'DELETE',
headers: {
Accept: 'application/json',
Cookie: `neptun-session=${sessionCookie}`,
},
}
)

if (!response.ok) {
throw new Error(`HTTP error! status: ${response.status}`)
}

return await response.json()
}

Notes

  • The session cookie is required for authentication.
  • The installation must belong to the specified user.
  • This operation cannot be undone.